<template>
<div class="vue-box">
  <div class="c-panel">
    <!-- 参数栏 -->
    <div class="c-title">检索参数</div>
    <el-form @submit.native.prevent class="conditional_filter">
      <sa-item v-model="p.search" type="text" name="模糊搜索" />
      <sa-item v-model="p.type" type="enum" jtype="4" :jv="dims.STAR_COMMENT_TARGET" name="评论资源" :def="{}" :clearable="true" />
      <sa-item v-model="p.status" type="enum" jtype="4" :jv="dims.AUDIT_STATUS" name="审核状态" :def="{}" :clearable="true" />
      <div class="c-item">
        <el-button type="primary" icon="el-icon-search" @click="p.current = 1; f5()">查询</el-button>
      </div>
    </el-form>
    <!-- ------------- 快捷按钮 ------------- -->
    <sa-item type="fast-btn" show="get,delete,export,reset" />
    <!-- 数据列表 -->
    <el-table ref="data-table" class="data-table" :data="dataList" border>
      <sa-td type="selection" width="45px" />
      <sa-td type="text" name="序号" prop="id" width="80px" />
      <sa-td type="text" name="资源名" prop="resourceName" />
      <sa-td type="enum" name="资源类型" prop="type" :jv="dims.STAR_COMMENT_TARGET" />
      <sa-td type="text" name="评论内容" prop="note" />
      <sa-td type="text" name="发布人" prop="uname" />
      <sa-td type="enum" name="审核状态" prop="status" :jv="dims.AUDIT_STATUS" />
      <sa-td type="datetime" name="创建时间" prop="createTime" />
      <sa-td name="操作" fixed="right" width="160px">
        <template slot-scope="s">
          <el-button type="text" @click="getInfo(s.row)">
            查看
          </el-button>
          <el-button type="text" @click="audit(s.row.id,1)" v-if="s.row.status===0">
            通过
          </el-button>
          <el-button type="text" @click="audit(s.row.id,2)" v-if="s.row.status===0">
            <span style="color: red;">
              拒绝
            </span>
          </el-button>
        </template>
      </sa-td>
    </el-table>
    <!-- 分页 -->
    <div v-if="dataCount">
      <sa-item type="page" :curr.sync="p.current" :size.sync="p.size" :total="dataCount" @change="f5()" />
    </div>
  </div>
</div>
</template>

<script>
import sa from '@/sa-frame/sa';

export default {
  name: 'commnets-list',
  data() {
    return {
      // 查询参数
      p: {
        current: 1,
        size: 10,
        search: null,
        status: null,
        type: null,
        sortField: null
      },
      dataCount: null,
      // 数据集合
      dataList: [],
      // 字典
      dims: {},
    }
  },
  created: function () {
    this.dims = sa.$sys.getCurd()
    this.f5();
    sa.onInputEnter();
  },
  methods: {
    // 刷新
    f5: function () {
      sa.ajax('/comments/getList', sa.removeNull(this.p), function (res) {
        this.dataList = res.data;
        this.dataCount = res.dataCount;
        // 刷新表格高度
        sa.f5TableHeight();
      }.bind(this), {
        type: "post"
      });
    },

    // 批量删除
    deleteByIds() {
      // 获取选中元素的id列表
      let selection = this.$refs['data-table'].selection;
      let ids = sa.getArrayField(selection, 'id');
      if (selection.length == 0) {
        return sa.msg('请至少选择一条数据')
      }
      // 提交删除
      sa.confirm('是否批量删除选中数据？此操作不可撤销', function () {
        sa.ajax('/comments/deleteByIds', {
          ids: ids
        }, function (res) {
          sa.ok(res.msg);
          this.f5()
        }.bind(this), {
          type: "post"
        })
      }.bind(this));
    },

    // 查看 - 根据选中的
    getBySelect: function () {
      var selection = this.$refs['data-table'].selection;
      if (selection.length === 0) {
        return sa.msg('请至少选择一条数据')
      }
      this.getInfo(selection[0]);
    },
    // 查看详情
    getInfo: function (data) {
      data.dims = this.dims
      sa.showModel('详情', () => import('./info'), data);
    },
    // 审核
    audit(id, status) {
      sa.ajax('/comments/audit', {
        id: id,
        status: status
      }, function (res) {
        sa.ok(res.msg);
        this.f5()
      }.bind(this), {
        type: "get"
      })
    }
  },
}
</script>

<style scoped></style>
